Method of changing logic circuit portion into gated clock portion and recording medium storing a program for carrying out the method

ABSTRACT

A method designs a logic circuit having a flip-flop which performs an on and off operation in response to a timing clock and a feedback loop. With such a structure, a logic circuit portion which operates in accordance with an enable signal automatically is extracted. Further, the logic circuit portion is formed by the use of a gated clock obtained by gating the timing clock via the enable signal. Thereby, the number of a change of the flip-flop in response to the timing clock can be largely reduced.

BACKGROUND OF THE INVENTION

[0001] This invention relates to a method of designing a large-scale integrated LSI circuit, and in particular, to a circuit design method using a logic synthesis technique.

[0002] Generally, as the LSI has been increased in size with a high speed, a circuit design method using the known EDA (electronic design automation) tool has increasingly became important. Such a circuit design method is normally classified into five phases, namely, (1) a system design, (2) a function/logic design, (3) a layout design, (4) a test design, and (5) a macrocell design.

[0003] In the function/logic design phase among the above phases, the LSI to be designed is expressed as a resistor or a combination between the resistors. In this event, the known RTL (resistor transfer level) description which is obtained in the system design phase is expressed by the use of a hardware description language, such as the known VHDL, to obtain a logic circuit (net list) of a gate level.

[0004] In this case, a constraint, a truth table, a logic equation and a state transition description and like are given as inputs in the function/logic design phase. Further, a state code of a state machine is assigned, a flip-flop is assigned and further, a combination logic is generated. Consequently, the logic circuit is generated as the gate level.

[0005] In this event, the logic circuit of the gate level which is used in the function/logic phase includes a variety of logic circuits. Under the circumstances, when the logic synthesis is directly carried out for the logic circuit which is described by the use of the VHDL, the constraints are often satisfied.

[0006] To this end, the logic is optimized within the range independent of a semiconductor manufacturing technology. Thereby, the number of the logic gates (chip area) and the number of logic stages are suitably adjusted so as to satisfy the constraints which are requested by an user. In such an adjustment, a redundant logic is eliminated, a logic is opened, and a multi-stage is carried out by the use of a nature of Boolean algebra. Finally, a mapping process is performed for the semiconductor manufacturing technology.

[0007] Herein, a low power consumption and a small chip are often considered as the constraint in the LSI. Conventionally, it is normal that the constraint, such as the power consumption and the chip area, is manually applied when the number of the logic gates and the number of the logic stages are adjusted. Consequently, the above conventional technique requires enough time to design the circuit.

[0008] On the other hand, the logic circuit to be designed includes, for example, a plurality of logic circuits each of which retains a signal value under a predetermined condition and inputs data under the other condition. In this event, this logic circuit is expressed by the use of a specific description, such as the VHDL. The logic circuit is logically synthesized by a combination of a multiplexer, a delay flip-flop and a feedback loop. Herein, the multiplexer operates by receiving an enable signal and a data signal. The flip-flop is connected to the multiplexer and is turned on and off in response to a timing clock. Further, the feedback loop is connected between the delay flip-flop and the multiplexer.

[0009] As mentioned before, the delay flip-flop itself repeats on and off operations every when the timing clocks are supplied to the logically synthesized combination of the multiplexer, the delay flip-flop and the feedback loop. Generally, electrical power is largely consumed when the delay flip-flop repeats the on and off operations. Consequently, the above logically synthesized logic circuit must be manually adjusted so as to reduce the power consumption of the logic circuit.

SUMMARY OF THE INVENTION

[0010] It is therefore an object of this invention to provide a circuit design method which is capable of designing a circuit at a short time.

[0011] It is another object of this invention to provide a circuit design method which is capable of realizing a lower power consumption.

[0012] It is still another object of this invention to provide a circuit design method which is applicable for a logic circuit having a feedback loop.

[0013] It is the other object of this invention to provide a circuit design method which is applicable for a logic circuit which retains a signal value under a predetermined condition and inputs a data signal under the other condition.

[0014] It is the other object of this invention to provide a circuit design method which is capable of realizing a lower power consumption and a small chip area by preventing a change due to unnecessary timing clocks.

[0015] A method of this invention designs a circuit having a flip-flop which performs an on and off operation in response to timing clocks and a feedback loop.

[0016] With such a structure, a logic circuit portion which operates in accordance with an enable signal automatically is extracted. Further, the logic circuit portion is formed by the use of gated clock. In this event, the timing clock is gated by the enable signal. Consequently, the number of a change of the flip-flop in response to the timing clock can be largely reduced.

[0017] Thus, according to this invention, the logic circuit having a lower power consumption can be obtained with a simple operation by automatically generating the logic circuit which is formed by the use of the gated clock. This also means that the circuit having a small chip area can be structured.

BRIEF DESCRIPTION OF THE DRAWINGS

[0018]FIG. 1 shows a structure of a logic circuit according to this invention;

[0019]FIG. 2 is a circuit diagram for explaining a principle of this invention in relation to FIG. 1;

[0020]FIG. 3 is a flow chart for explaining a circuit design method according to an example of this invention;

[0021]FIG. 4 is a circuit diagram for explaining a circuit which requires a pretreatment process according to this invention;

[0022]FIG. 5 is a circuit diagram for explaining the pretreatment process which is performed for the circuit illustrated in FIG. 4;

[0023]FIG. 6 is a circuit diagram for explaining variation of logic circuits which are formed by the use of a gated clock process and which are generated according to this invention; and

[0024]FIG. 7 is a flow chart for explaining an operation for generating a logic circuit which is formed by the use of a gated clock process according to this invention.

DESCRIPTION OF THE PREFERRED EMBODIMENTS

[0025] Referring to FIGS. 1 and 2, description will be made about a principle of this invention.

[0026] Before explaining FIGS. 1 and 2, it is assumed that a logic relation between hardware is specified by the following description by the use of the hardware description language VHDL.

[0027] if(clock'event and clock=‘1’) then

[0028] if(enable=‘0’) then

[0029] data2<=data1:

[0030] endif:

[0031] endif:

[0032] As illustrated in FIG. 1, a circuit which is logically synthesized on the basis of the above-mentioned description is structured by a combination of a delay flip-flop 1 (DFF) and a multiplexer 2 (MUX). Further, the delay flip-flop (DFF) and the multiplexer (MUX) are connected to each other via feedback loop 3. More specifically, the multiplexer 2 (MUX) in the logically synthesized circuit is given data (data1, namely (d)) and data (data 2, namely (h)) which is fed back from the delay flip-flop 1 (DFF).

[0033] With such a structure, when an enable signal (e) is equal to a logic “1”, the data 2 (h) is selected. On the other hand, when the enable signal (e) is equal to a logic “0”, the data 1 is selected to be supplied to the delay flip-flop 1 (DFF) as a signal f. A timing clock (clock), namely, (c) is given to the delay flip-flop 1 (DFF) and the signal (f) is retained in the delay flip-flop 1 (DFF) in response to the timing clock (c). It is clear from this operation that when the enable signal (e) is equal to a logic “0”, the input data and the output data of the delay flip-flop 1 (DFF) are identical to each other. That is, the data 1 is equal to the date 2, and namely, (d) is equal to (h).

[0034] As illustrated in FIG. 1, the logically synthesized logic circuit has the delay flip-flop 1 (DFF) which performs the on and off operation in response to the timing clock (c). Therefore, with such a structure, every time when each cycle of the clock timing (c) begins and finishes, the delay flip-flop 1 (DFF) repeats the on and off operation. Consequently, the power consumption becomes large.

[0035] In this event, it is preferable to reduce the on and off operation of the delay flip-flop 1 (DFF) in order to reduce the power consumption. Taking this into consideration, the circuit according to this invention is automatically changed into a gated clock circuit so as to suppress a change due to the clocks (c) when the above-mentioned expression is used.

[0036] Referring to FIG. 2, the multiplexer 1 (MUX) is removed and the delay flip-flop 1 (DFF) is left in the logic circuit which is formed by the use of the gated clock. Further, the data 1 (d) is directly given to the delay flip-flop 1 (DFF) in the circuit illustrated in FIG. 2. On the other hand, the enable signal (e) and the timing clock (c) are given to an OR gate OR1 4 and are supplied to the delay flip-flop 1 (DFF) via the OR gate OR1 4.

[0037] In the circuit changed as illustrated in FIG. 2, only when the enable signal (e) is equal to a logic “0”, the timing clock (c) is given to the delay flip-flop 1 (DFF). When the enable signal (e) is equal to “1”, namely, (d) is given to the delay flip-flop 1 (DFF) and the delay flip-flop 1 (DFF) does not perform the on and off operation in response to the timing clock (c). Consequently, the on and off operations of the delay flip-flop 1 (DFF) can be remarkably reduced. Therefore, the power consumption can be also reduced. Thus, this invention is characterized in that the invention has the logic synthesis tool for automatically changing the logically synthesized logic circuit illustrated in FIG. 1 into the logic circuit illustrated in FIG. 2.

[0038] As mentioned before, it is judged whether or not the gated clock illustrated in FIG. 2 can be automatically extracted in the circuit design method according to this invention. When the gated clock is extracted, the circuit in FIG. 2 which is formed by the use of the gated clock is generated.

[0039] Subsequently, referring to FIG. 3 together with FIG. 1, description will be made about the circuit design method according to an example of this invention.

[0040] In a flow chart illustrated in FIG. 3, the flip-flop (hereinafter, abbreviated to FF) which is formed by the use of the gated clock will be extracted.

[0041] First, it is detected whether or not the operation is completed for all of FFs in the step S1.

[0042] If the operation for all of FFs is not completed in the step S1, the step S1 goes to the step S2 to select FF. Herein, the selected FF is represented by g in the step S2.

[0043] Next, a logic function of an input f is produced with respect to the selected g in the step 3.

[0044] In the case of the delay flip-flop 1 (DFF) illustrated in FIG. 1, the logic function with respect to the input f can be represented by the following equation.

f=e·h+eb·d

[0045] Herein, e and eb are the enable signal and a Not enable signal (called an enable bar signal) thereof, respectively. Further, h is an output signal of g while d is a data signal (data 1).

[0046] Subsequently, it is judged whether or not the output signal h of g is included in the logic function with respect to the output f in the step S4. As a result of the judgement, if h is included, the step S4 proceeds to the step S5. If h is not included, the process returns to the step S1. In the illustrated example, the process proceeds to a calculation process of a co-factor in the step S5 and the latter because h is included in the logic function with respect to the input f. The co-factor can be calculated by inputting a logic “1” and a logic “0” as e and eb.

[0047] Specifically, the co-factor can be calculated by the use of the following equation.

F(e)=1h+0d=h

[0048] In FIG. 3, after the co-factor is calculated, the operation process transfers from the step S5 to the step S6.

[0049] In the step S6, it is judged whether or not a relation of F(e)=h is satisfied. In this example, the operation process transfers from the step S6 into the step S7 to generate the logic circuit which is formed by the use of the gated clock because the above condition is satisfied. —On the other hand, when the above co-factor does not satisfy the above-mentioned condition in the step S6, the operation process goes to the step S8 to calculate the co-factor for the enable signal eb base upon the following equation.

F(eb)=0d+1d=d

[0050] Successively, judgement is made about whether or not a relation of F(eb)=h is satisfied in the step S9. In this example, the step 9 is returned back to the step S1 to select another flip-flop and to repeat the same operation because the above relation is not satisfied in the step S9. This operation is carried out for all of the flip-flops until all of the logic circuits which are formed by the use of the gated clock are generated.

[0051] In the above-mentioned example, description has been made about the extracting operation of the gated clock in a single hierarchy. Alternatively, the extracted gated clock logic circuits may be combined into a hierarchy of a further high level. Thereby, a single logic circuit which is controlled by a single enable signal e and a single clock c may be combined.

[0052] Subsequently, when the gated clock logic circuit is generated as shown in the step S7 in FIG. 3, it is required that the input f for the selected flip-flop g is single. For instance, when the signal f which is obtained by logically calculating the enable signal e and the output h of the delay flop-flop 1 (DFF) is branched or fanned out other than the delay flip-flop 1 (DFF) as illustrated in FIG. 4, the gated clock illustrated in FIG. 2 is not accurately and logically synthesized. Thus, when the above branch exists, a pretreatment process must be carried out to equivalently constitute the circuit illustrated in FIG. 1.

[0053] Referring to FIG. 5, description will be made about the pretreatment process executed when the signal f which is logically calculated is branched or fanned out.

[0054] For example, the multiplexer (MUX) 2 illustrated in FIG. 4 is doubled to structure a multiplexer 20 a (MUX1) and a multiplexer 20 b (MUX2) which are equivalent to each other. In this event, the multiplexer 20 a (MUX1) and the delay flip-flop 1 (DFF) is formed by the use of gated clock in the same manner with FIG. 2. On the other hand, a circuit (not shown) which is connected to the multiplexer 20 b (MUX2) may be dealt with the other logic circuit.

[0055] Moreover, when the gated clock logic circuit is generated, it is desirable that consideration is made about a case that the data d is stored to the flip-flop g which is selected at the rise of the clock and another case that the date d is stored to the flip-flop g which is selected at the fall of the clock. Further, another consideration may be preferably made about a case that the enable signal e is sometimes equal to a logic “1” or “0”.

[0056] In FIG. 6, a structure of a logic circuit which stores the data d on the basis of the rise clock is illustrated in a first column. On the other hand, a structure of a logic circuit which stores the data d on the basis of the fall clock is illustrated in a second column. In this case, even when the data d is stored in response to the rising clock, the logic circuit which satisfies the condition of f(e)=h and the logic circuit which satisfies the condition of f(eb)=h are structured, respectively. Therefore, four logic circuits which correspond to the respective conditions and clocks are illustrated in FIG. 6.

[0057] More specifically, when the data d is stored in response to the rise clock and the condition f(e)=h is satisfied, the gated clock logic circuit (thereinafter, referred to as a logic circuit A) can be obtained by using an OR gate 60 between the enable signal e and the timing clock c in the same manner with FIG. 2. Further, when the date d is stored in response to the rise clock and the condition f(eb)=h is satisfied, the corresponding logic circuit (thereinafter, referred to as a logic circuit B) can be obtained by inputting Not signal (namely, eb) of the enable signal e to the OR gate 61.

[0058] Moreover, the logic circuit which stores the data d in response to the fall clock and satisfies the condition of f(e)=h can be formed by the use of the gated clock via an AND gate 62 which is given the enable bar signal eb of the enable signal e and the clock c, and is thereinafter called a logic circuit C. In addition, the logic circuit which stores the data d in response to the fall clock and satisfies the condition of f(eb)=h can be formed by the use of gated clock via an AND gate 63 which is given the enable signal e and the clock c, and is thereinafter called as a logic circuit D.

[0059] Referring to FIG. 7, detail description will be made about the operation of the step S7 for generating the gated clock logic circuit in FIG. 3.

[0060] referring to FIG. 7, description will be made about the operation for performing the pretreatment process shown in FIGS. 4 and 5 and obtaining either one of the gated clock logic circuits A through D in FIG. 6.

[0061] First, it is judged whether or not the logic circuit is required to be doubled in the step SS1. This judgement can be easily carried out by detecting whether or not the signal f is branched or fanned out. When the logic circuit is required to be doubled, the circuit with respect to the signal f (for example, the multiplexer MUX) is doubled in the step SS2.

[0062] When the circuit is doubled, the process transfers to the step SS3. On the other hand, the circuit is not required to be doubled, the process directly goes to the step SS3.

[0063] Next, it is judged whether or not the selected flip-flop (FF) stores the data at either one of the rise and the fall of the timing clock in the step SS3. As a result of the judgement, when the data is stored at the rise clock, the step SS4 is successively carried out after the step SS3.

[0064] In the step SS4, it is judged whether or not the condition of f(e)=h is satisfied. When the condition is satisfied, the logic circuit A illustrated in FIG. 6 in is determined in the step SS5. On the other hand, when the above condition is not satisfied, the logic circuit B in FIG. 6 is determined in the step SS6.

[0065] On the other hand, when it is judged that the data is stored at the fall clock of the flip-flop (FF) in the step SS3, the process operation transfers to the step SS7. In the step SS7, it is judged whether or not the condition of f (eb)=h is satisfied. When this condition is satisfied, the logic circuit C illustrated in FIG. 6 is determined in the step SS8. Further, when the above condition is not satisfied, the logic circuit D in FIG. 6 is determined in the step SS9.

[0066] Above mentioned before, the gated clock logic circuits are sequentially and automatically determined according to this invention. Consequently, a manual adjustment can be remarkably simplified. 

What is claimed is:
 1. A method of designing a circuit having a flip-flop which performs an on and off operation in response to a timing clock, comprising the steps of: automatically extracting a logic circuit portion which operates in accordance with an enable signal; and changing said logic circuit portion into a gated clock portion which is formed by the use of a gated clock obtained by gating the timing clock with reference to the enable signal.
 2. A method as claimed in claim 1 , wherein: said changing step is carried out to reduce the number of a change of said flip-flop in response to the timing clock.
 3. A method as claimed in claim 1 , wherein: said changing step comprises; a step for combining said gated clock portion with a common gate; and a step for raising said gate to a hierarchy of a further high level.
 4. A method as claimed in claim 1 , wherein: said extracting step comprises the steps of; selecting said flip-flop; and expressing a logic function with respect to an output of said flip-flop.
 5. A method as claimed in claim 4 , wherein: said extracting step further comprises the steps of; detecting whether or not the logic function includes an output of said flip-flop; and calculating a co-factor for the enable signal with respect to the logic function; and judging whether or not the logic circuit portion exists.
 6. A method as claimed in claim 1 , wherein: said extracting step further comprises a step for performing a pretreatment to judge whether or not an input of said flip-flop is branched.
 7. A recording medium which stores a program for executing the following procedures as a tool for EDA (electronic design automation): automatically extracting a logic circuit portion which operates in accordance with an enable signal from a circuit having a flip-flop which performs an on and off operation in response to a timing clock and a feedback loop; and changing said logic circuit portion into a gated clock proportion which is formed by the use of a gated clock by gating the timing clock via the enable signal.
 8. A recording medium as claimed in claim 7 , wherein: said changing step is carried out in order to reduce the number of a change of said flip-flop in response to the timing clock.
 9. A recording medium as claimed in claim 7 , wherein: said changing step comprises the steps of; combining said gated clock portion with a common gate; and raising said gate to a hierarchy of a further high level.
 10. A recording medium as claimed in claim 7 , wherein: said extracting step comprises the steps of; selecting said flip-flop; and expressing a logic function with respect to an output of said flip-flop.
 11. A recording medium as claimed in claim 10 , wherein: said extracting step comprises the steps of; detecting whether or not said logic function includes an output of said flip-flop; and calculating a co-factor for the enable signal with respect to the logic function; and judging whether or not the logic circuit portion exists.
 12. A recording medium as claimed in claim 7 , wherein: said extracting step further comprises a step for performing a pretreatment to judge whether or not an input of said flip-flop is branched. 